



TA: Po-Chen Wu (吳柏辰)



#### Outline

- Review: Ports, Channels, and Interfaces
- Transaction Level Modeling
- Lab 2 Practice: Simple FIFO / Perf







#### Definition

- Interface : Abstract class
- Channel : Implementation class
- Port : Interface pointer





# Pre-defined SystemC Interface

- sc\_fifo\_in\_if
- sc\_fifo\_out\_if
- sc\_signal\_in\_if
  - □ sc\_in ≈ \*(sc\_port<sc\_signal\_in\_if>)
- sc\_signal\_out\_if
  - □ sc\_out ≈ \*(sc\_port<sc\_signal\_out\_if>)
- sc\_signal\_inout\_if
  - □ sc\_inout ≈ \*(sc\_port<sc\_signal\_inout\_if>)
- ....



# Why do we customize interface?

- There are so many predefined interfaces for functional/architecture modeling, why?
  - □ Reduce design complexity, increase simulation speed, etc.
- Abstraction of communication, encapsulate lowlevel details
  - □ Physical: define higher level data types
  - □ Temporal: hide protocol details
  - □ Special purpose: debug supporting functions, etc.
- Help to refine models smoothly



# Guidelines for Interface Design\*

- Minimize the number of interfaces
- Layer specialized interfaces on more general interfaces and use the more general interfaces as much as possible to increase opportunities for channel reuse.
- Use class inheritance to group common interface methods and to reduce code duplication.
- Create a unified interface class from separate interfaces classes using C++ multiple inheritance.

<sup>\*</sup>T. Grotker, S. Liao, G. Martin, S. Swan, System Level Design with SystemC, Kluwer Academic Publisher, 2002







## Transaction Level Modeling

- Majorly used for functional modeling, platform modeling, and testbench constructing.
- Communication mechanisms such as buses or FIFOs are modeled as channel.
- Modules use interface to access channels
- Allow refining on implementation of interface



# TLM for System Level Design

- Emphasis more on functionality of data transfer: what data are transferred, to and from what locations.
- Emphasis less on their actual implementation, that is, on the actual protocol used for data transfer.







#### Run a simple example

- Try code/simple\_perf/
  - Open simple\_perf.sln in Visual Studio 2013
- This is a simple FIFO example
  - Customized read/write interface
    - Inherited from sc\_interface
  - ☐ Hierarchical channel
    - Inherited from sc\_channel
    - In SystemC, sc\_channel and sc\_module are identical! Hierarchical channel == Module



## Simple FIFO / Simple Perf





# Requirement

- Add bool isEmpty() to read\_if
- Add bool isFull() to write\_if
- Use these functions in producer and consumer to show the blocking access explicitly.